## LABORATORIO #8 ELECTRONICA DIGITAL

## Ejercicio 1 (CONTADOR)

```
iverilog -o Alejandro-Duarte-19446-seccion21-contador_tb.out -D VCD_OUTPUT=Alejandro-Duar
.v Alejandro-Duarte-19446-seccion21-contador_tb.v
vvp Alejandro-Duarte-19446-seccion21-contador_tb.out
/CD info: dumpfile Alejandro-Duarte-19446-seccion21-contador_tb.vcd opened for output.
eset En load load2 | q
         000000000000
         000000000000
                           000000000000
         0000000000000
                           0000000000000
         000000000000
                           0000000000001
         000000000000
                           0000000000010
         000000000000
                           000000000011
         000000000000
                           000000000100
000000000101
                           000000000110
         000000000000
                           000000000111
         000000000000
                           000000001000
         000000000000
                           000000001001
         000000000000
                           000000001010
                           000000001011
         000000010010
0000000000000
                           000000010010
                           000000010011
                           000000010100
         000000000000
                           000000010101
         0000000000000
                           000000010110
         000000000000
                           000000010111
         000000000000
                           000000011000
         000000000000
                           000000011000
         000000000000
                           000000000000
  0
0
         000000000000
                           0000000000001
         000000000000
                           000000000010
         0000000000000
                           0000000000011
         000000000000
                           000000000100
         000000001100
                           000000001100
         000000000000
                           000000001101
                           000000001110
                           000000001111
         0000000000000
                           000000010000
         0000000000000
                           000000010001
         000000000000
                           000000010010
         000000000000
                           000000010011
         000000000000
                           000000010100
         000000000000
                           000000010101
         000000000000
                           000000010110
                           000000010111
         000000000000
                           000000010111
tkwave Alejandro-Duarte-19446-seccion21-contador_tb.vcd Alejandro-Duarte-19446-seccion2;
```



Para el modulo del contador se establecieron 4 variables de 1 bit, en los cuales está el clk, reset, En y el load, también se determinan dos variables con buses de 12 bits (load2 y q). En este módulo se utiliza always con nonblocking para que trabaje en paralelo todas las condiciones implementadas, entre estas esta la condición que cuando load se active se cargaría el valor de load2 a la salida q del contador, también están las condiciones de cuando el ennable suma 1 bit cada tiempo de reloj y cuando se activa el reset vuelvo a valores iniciales la salida q.

## Ejercicio 2 (MEMORIA ROM)

```
Localidad
            Respuesta
000000000000 |
              01001000
0000000000001
             01000000
000000000010 | 01011111
000000000011 | 00100110
000000000100 | 01010001
000000000101 | 00001010
000000000110 | 00010001
000000000111
             00011010
000000001000
            00101011
000000001001 | 00000111
gtkwave Alejandro-Duarte-19446-21-memoria tb.vcd Alejandro-Duarte-19446-21-memoria tb.gtkw
```



Para el modulo de memoria se implementa un arreglo de 8 bits por, aproximadamente, cuatro mil localidades. En este lee el documento nombrado memory.list que tiene números binarios de 8 bits que pasan a la variable cerebro que este en el arreglo establecido para luego establecer los datos del archivo externo en la variable respuesta de 8 bits.

## Ejercicio 3 (ALU)





Para este modulo se implemento la ALU que esta descrita en el libro, en el cual se implentan 8 diferentes comandos que se le pueden ver en el código. Para la realización de este se implementaron tres variables de buses de 4 bits y una variable de 3 bits que será la que determine que comando se utilizará para efectuar sobre las variables 1 y 2 para que dicho resultado se guarde en la variable respuesta.